<?php
/**
 * @title 402. 移掉 K 位数字 - 单调栈
 * @author start2004
 */

// ini_set("memory_limit", "128M");

// class Solution {
//
//     function find() {
//
//     }
// }

class Solution {

    /**
     * @param String $num
     * @param Integer $k
     * @return String
     */
    function removeKdigits($num, $k) {
        /**
         * @since 2021/11/17 栈
         */
        $stackArray = [];

        /**
         * @since 2021/11/17 指针
         */
        $p = -1;

        /**
         * @since 2021/11/23 每个数字依次入栈
         */
        for($i = 0; $i<strlen($num); $i++){
            $n = $num[$i];

            /**
             * @since 2021/11/23 无需移除，直接进栈
             */
            while($p >= 0){
                /**
                 * @since 2021/11/23 k=0, 指针无法移动，直接进栈
                 */
                if($k == 0){
                    $p++;
                    $stackArray[$p] = $n;
                    break;
                } elseif($n >= $stackArray[$p]) {
                    /**
                     * @since 2021/11/23 更大的数字，进栈
                     */
                    $p++;
                    $stackArray[$p] = $n;
                    break;
                } else {
                    /**
                     * @since 2021/11/23 更小的数字, 指针移动
                     */
                    $k--;
                    $p--;
                }
            }

            /**
             * @since 2021/11/23 空栈，但`0`不能进栈
             */
            if($p == -1 AND $n != "0"){
                $p++;
                $stackArray[$p] = $n;
            } else {}
        }

        /**
         * @since 2021/11/23 取出栈数字
         */
        if($p == -1){
            return "0";
        } else {}
        $num = implode("", $stackArray);
        $num = substr($num, 0, $p+1);

        /**
         * @since 2021/11/23 收官，k是否有多余
         */
        if($k > 0){
            $num = substr($num, 0, strlen($num)-$k);
            if($num == ""){
                return "0";
            } else {}
        } else {}

        /**
         * @return
         */
        return $num;
    }
}

/**
 * @url http://127.0.0.1/leetcode/202111/2021.11.16_3.php
 */
$datas = [
    ["1234567", 5], // 12
    ["1432219", 3], // 1219
    ["1002", 1],
    ["1002", 2],
    ["100", 1],
];

include_once dirname(__DIR__) . DIRECTORY_SEPARATOR ."xhprof.php";
$xhprof = new Xhprof();
foreach ($datas as $data){
    if(count($data) <= 20){
        var_dump($data);
    } else {
        var_dump(count($data));
    }

    $obj = new Solution();
    $result = $obj->removeKdigits(...$data);
    // $result = $obj->($xhprof->tree($data));
    // $result = $obj->($xhprof->listNode($data));
    // $result = $obj->find(...$data);
    var_dump($result);
    // if(count($result)<=20){
    //     var_dump($result);
    // } else {
    //     var_dump(count($result));
    // }
    echo str_repeat(PHP_EOL, 3);
    echo str_repeat("<br>", 3);
}

// foreach ($datas as $data){
//     $obj = new $data[0][0](...$data[1][0]);
//
//     for ($i=1; $i<count($data[0]); $i++){
//         $func = $data[0][$i];
//         $param = $data[1][$i];
//         $result = $obj->$func(...$param);
//
//         echo $data[0][$i] ."(\"". implode(",", $data[1][$i]) ."\") ";
//             if($result === true){
//                 echo "True";
//             } elseif($result === false) {
//                 echo "False";
//             } elseif($result === null) {
//                 echo "Null";
//             } elseif(is_array($result)) {
//                 var_dump($result);
//             } else {
//                 echo $result;
//             }
//         echo PHP_EOL;
//     }
//
//     echo str_repeat(PHP_EOL, 3);
// }
$xhprof->end();
